package com.huike.web.controller.review;


import com.huike.common.core.controller.BaseController;
import com.huike.common.core.domain.AjaxResult;
import com.huike.common.core.page.TableDataInfo;
import com.huike.review.pojo.Review;
import com.huike.review.service.ReviewService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import java.util.List;

/**
 * 该Controller主要是为了复习三层架构以及Mybatis使用的，该部分接口已经放开权限，可以直接访问
 * 同学们在此处编写接口通过浏览器访问看是否能完成最简单的增删改查
 */
@RestController
@RequestMapping(value = "/review")
public class MybatisReviewController extends BaseController {

    @Autowired
    private ReviewService reviewService;

    /**=========================================================新增数据============================================*/
    @GetMapping(value = "/saveData/{name}/{age}/{sex}")
    public AjaxResult saveData(@PathVariable("name") String name,
                         @PathVariable("age") Integer age,
                         @PathVariable("sex") String sex){
        Review review = new Review();
        review.setName(name);
        review.setAge(age);
        review.setSex(sex);
        int row = reviewService.saveData(review);
        return AjaxResult.success("成功插入:"+ row +"条数据");
    }

    @PostMapping(value = "/saveData")
    public AjaxResult saveData(Review review){
        int row = reviewService.saveData(review);
        return AjaxResult.success("成功插入:"+ row +"条数据");
    }

    /**=========================================================删除数据=============================================*/
    @DeleteMapping(value = "/remove/{id}")
    public AjaxResult delete(@PathVariable("id") Integer id){
        return AjaxResult.success("成功删除:"+reviewService.delete(id)+"条数据");
    }

    /**=========================================================修改数据=============================================*/
    @PutMapping("/update")
    public AjaxResult update(Review review){
        reviewService.update(review);
        return AjaxResult.success("修改成功");
    }

    /**=========================================================查询数据=============================================*/

    /**=========================================================分页查询数据=============================================*/
    @GetMapping(value = "/getDataByPage")
    public TableDataInfo getDataByPage(){
        startPage();
        List<Review> list = reviewService.getDataByPage();
        return getDataTablePage(list);
    }

    /**=========================================================根据ID查询数据=============================================*/
    @GetMapping(value = "/getById")
    public AjaxResult findById(Integer id){
        Review review = reviewService.findById(id);
        return AjaxResult.success("操作成功",review);
    }

}